### VE270 RC Week 5 Combinational Circuit

Shi Li 2019.10.9

#### Combinational Circuit

- The output depends only upon the present combination of its inputs
- Input change ←⇒ Output change

# Combinational Circuit compared with Sequential Circuit

• Truth table for a combinational circuit

| p | q | pvq |
|---|---|-----|
| T | T | T   |
| T | F | T   |
| F | T | T   |
| F | F | F   |

• Characteristic table for a sequential circuit

|   | S(t) | R(t) | Q(t) |    | Q(t | +∆) Q+      |
|---|------|------|------|----|-----|-------------|
| • | 0    | 0    | 0    | Π  | 0   | hold        |
|   | 0    | 0    | 1    |    | 1   | rioid       |
|   | 0    | 1    | 0    | П  | 0   | reset       |
|   | 0    | 1    | 1    |    | 0   | 10301       |
|   | 1    | 0    | 0    | П  | 1   | set         |
|   | 1    | 0    | 1    |    | 1   | 301         |
|   | 1    | 1    | 0    | П  | X   | not allowed |
|   | 1    | 1    | 1    |    | Χ   |             |
|   |      |      |      | Ι' |     |             |

#### Design Process

- Capture the function
  - truth table/equation from requirements
- Convert to equation
  - k-map logic optimization
- Implement the circuit
  - from the optimized logic expression

# Design Process Exercise 1 (modified from 2018 Fall RC Slides)

- Now imagine that you are the smart tech support for a spy, you have to design a lock for his secret suitcase:
  - Each input is a 4-bit binary number  $x_1x_2x_3x_4$ ;
  - 1010 opens the suitcase;
  - 0100, 0101, 1100, 1101, 1111 blows the suitcase up (doesn't matter whether the suitcase opens or not);
  - Output x for whether to open the suitcase and y for whether to make it explode

## Combinational Building Blocks 1. MUX

- Example: 4 to 1 Mux
- Using 2 "switches" to choose one of the four input signals



 Question: If we have 35 input from i0 to i34, how much "switches" do we need?

#### Combinational Building Blocks 2. Adder: Half Adder



| Α | В | Sum | Carry |
|---|---|-----|-------|
| 0 | 0 | 0   | 0     |
| 0 | 1 | 1   | 0     |
| 1 | 0 | 1   | 0     |
| 1 | 1 | 0   | 1     |





#### Combinational Building Blocks 2. Adder: Full Adder

• The first way to implement a full adder.



Sum = A'B'C + A'BC' + AB'C' + ABC  
= 
$$\Sigma$$
 m(1, 2, 4, 7)  
Carry = A'BC + AB'C + ABC' + ABC  
=  $\Sigma$  m(3, 5, 6, 7)



#### Combinational Building Blocks 2. Adder: Full Adder

• Is there any way to make it simpler?



Question: Why use OR gate here?

#### Combinational Building Blocks 2. Adder: Carry-Ripple Adder

• For a carry-ripple adder with 4-bit input, it generates 5-bit output.



#### Combinational Building Blocks

- 2. Adder: Subtractor (for 2's complement numbers)
- When we do subtraction, we need to
- 1. add inverters to B input
- 2. set C0 to 1



### Combinational Building Blocks Exercise 2

- Use 2-1 muxes to design a simple 4-bit Arithmetic-Logic Unit.
- The input is Cin, A0~A3, B0~B3, X.
- The output is Cout, Overflow, S0~S3.

- Specifications: When X=1, S=A+B. When X=0, S=A-B.
- You do not need to draw the complete circuit. Use blocks (mux, full adder, etc) instead.

## Combinational Building Blocks 3. Encoder & Decoder

| Inputs |       |       |       |       |       |       | Outputs |   | Inputs |   |   | Outputs |   |       |       |       |       |       |       |       |       |
|--------|-------|-------|-------|-------|-------|-------|---------|---|--------|---|---|---------|---|-------|-------|-------|-------|-------|-------|-------|-------|
| $D_0$  | $D_1$ | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | $D_7$   | х | у      | z | Χ | У       | Z | $D_0$ | $D_1$ | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | $D_7$ |
| 1      | 0     | 0     | 0     | 0     | 0     | 0     | 0       | 0 | 0      | 0 | 0 | 0       | 0 | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0      | 1     | 0     | 0     | 0     | 0     | 0     | 0       | 0 | 0      | 1 | 0 | 0       | 1 | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0      | 0     | 1     | 0     | 0     | 0     | 0     | 0       | 0 | 1      | 0 | 0 | 1       | 0 | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     |
| 0      | 0     | 0     | 1     | 0     | 0     | 0     | 0       | 0 | 1      | 1 | 0 | 1       | 1 | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 0      | 0     | 0     | 0     | 1     | 0     | 0     | 0       | 1 | 0      | 0 | 1 | 0       | 0 | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 0      | 0     | 0     | 0     | 0     | 1     | 0     | 0       | 1 | 0      | 1 | 1 | 0       | 1 | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 0      | 0     | 0     | 0     | 0     | 0     | 1     | 0       | 1 | 1      | 0 | 1 | 1       | 0 | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 1       | 1 | 1      | 1 | 1 | 1       | 1 | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |

### Combinational Building Blocks 3. Encoder & Decoder

- Decoder: N inputs,  $2^N$  outputs
- Enable e (Question: How to implement it in the circuit?)
- Use decoder to implement any combinational circuit



### Combinational Building Blocks 4. Buffer & Tri-state Buffer

- Why we use buffers?
  - Amplify the driving capability of a signal
  - Insert delay
  - Protect input from output
- Why we use tri-state buffer?
  - Provide another state "Z"
  - Z: high impedence



| В                     | Α |   | В | Α                |    | В | Α                     | C |
|-----------------------|---|---|---|------------------|----|---|-----------------------|---|
| 0                     | 0 | Z | 0 | 0                | Z  | 0 | 0                     | 0 |
| 0                     | 1 | Ζ | 0 | 1                | ΙZ | 0 | 1                     | 1 |
| 1                     | 0 | 0 | 1 | 0                | 1  | 1 | 0                     | Ζ |
| B<br>0<br>0<br>1<br>1 | 1 | 1 | 1 | 0<br>1<br>0<br>1 | 0  | 1 | A<br>0<br>1<br>0<br>1 | Z |